//compass
// ---- Created with 3Dmigoto v1.2.67 on Fri Dec 01 18:49:09 2017
Texture2D<float4> t16 : register(t16);

Texture2D<float4> t7 : register(t7);

Texture2D<float4> t6 : register(t6);

Texture2D<float4> t5 : register(t5);

Texture2D<float4> t4 : register(t4);

Texture2D<float4> t3 : register(t3);

Texture2D<float4> t2 : register(t2);

Texture2D<float4> t1 : register(t1);

Texture2D<float4> t0 : register(t0);

SamplerState s7_s : register(s7);

SamplerState s6_s : register(s6);

SamplerState s5_s : register(s5);

SamplerState s4_s : register(s4);

SamplerState s3_s : register(s3);

SamplerState s2_s : register(s2);

SamplerState s1_s : register(s1);

SamplerState s0_s : register(s0);

cbuffer cb11 : register(b11)
{
  float4 cb11[192];
}

cbuffer cb10 : register(b10)
{
  float4 cb10[4];
}

cbuffer cb6 : register(b6)
{
  float4 cb6[10];
}

cbuffer cb5 : register(b5)
{
  float4 cb5[14];
}

cbuffer cb1 : register(b1)
{
  float4 cb1[3];
}

cbuffer cb0 : register(b0)
{
  float4 cb0[18];
}




// 3Dmigoto declarations
#define cmp -
Texture1D<float4> IniParams : register(t120);
Texture2D<float4> StereoParams : register(t125);


void main(
  float4 v0 : SV_POSITION0,
  linear centroid float4 v1 : TEXCOORD6,
  linear centroid float4 v2 : TEXCOORD7,
  linear centroid float4 v3 : TEXCOORD4,
  float4 v4 : TEXCOORD5,
  linear centroid float4 v5 : COLOR0,
  linear centroid float4 v6 : COLOR1,
  linear centroid float3 v7 : TEXCOORD10,
  linear centroid float w7 : TEXCOORD11,
  linear centroid float4 v8 : TEXCOORD0,
  linear centroid float4 v9 : TEXCOORD1,
  linear centroid float4 v10 : TEXCOORD2,
  linear centroid float4 v11 : TEXCOORD3,
  out float4 o0 : SV_Target0)
{
  const float4 icb[] = { { 0.0153846154, 0, 0, 0},
                              { 0.753846169, 0, 0, 0},
                              { 0.200000, 0, 0, 0},
                              { 0.938461542, 0, 0, 0},
                              { 0.0615384616, 0, 0, 0},
                              { 0.800000, 0, 0, 0},
                              { 0.246153846, 0, 0, 0},
                              { 0.984615386, 0, 0, 0},
                              { 0.507692337, 0, 0, 0},
                              { 0.261538476, 0, 0, 0},
                              { 0.692307711, 0, 0, 0},
                              { 0.446153849, 0, 0, 0},
                              { 0.553846180, 0, 0, 0},
                              { 0.307692319, 0, 0, 0},
                              { 0.738461554, 0, 0, 0},
                              { 0.492307693, 0, 0, 0},
                              { 0.138461545, 0, 0, 0},
                              { 0.876923084, 0, 0, 0},
                              { 0.0769230798, 0, 0, 0},
                              { 0.815384626, 0, 0, 0},
                              { 0.184615389, 0, 0, 0},
                              { 0.923076928, 0, 0, 0},
                              { 0.123076923, 0, 0, 0},
                              { 0.861538470, 0, 0, 0},
                              { 0.630769253, 0, 0, 0},
                              { 0.384615391, 0, 0, 0},
                              { 0.569230795, 0, 0, 0},
                              { 0.323076934, 0, 0, 0},
                              { 0.676923096, 0, 0, 0},
                              { 0.430769235, 0, 0, 0},
                              { 0.615384638, 0, 0, 0},
                              { 0.369230777, 0, 0, 0},
                              { 0.0461538471, 0, 0, 0},
                              { 0.784615397, 0, 0, 0},
                              { 0.230769232, 0, 0, 0},
                              { 0.969230771, 0, 0, 0},
                              { 0.0307692308, 0, 0, 0},
                              { 0.769230783, 0, 0, 0},
                              { 0.215384617, 0, 0, 0},
                              { 0.953846157, 0, 0, 0},
                              { 0.538461566, 0, 0, 0},
                              { 0.292307705, 0, 0, 0},
                              { 0.723076940, 0, 0, 0},
                              { 0.476923078, 0, 0, 0},
                              { 0.523076952, 0, 0, 0},
                              { 0.276923090, 0, 0, 0},
                              { 0.707692325, 0, 0, 0},
                              { 0.461538464, 0, 0, 0},
                              { 0.169230774, 0, 0, 0},
                              { 0.907692313, 0, 0, 0},
                              { 0.107692309, 0, 0, 0},
                              { 0.846153855, 0, 0, 0},
                              { 0.153846160, 0, 0, 0},
                              { 0.892307699, 0, 0, 0},
                              { 0.0923076943, 0, 0, 0},
                              { 0.830769241, 0, 0, 0},
                              { 0.661538482, 0, 0, 0},
                              { 0.415384620, 0, 0, 0},
                              { 0.600000, 0, 0, 0},
                              { 0.353846163, 0, 0, 0},
                              { 0.646153867, 0, 0, 0},
                              { 0.400000, 0, 0, 0},
                              { 0.584615409, 0, 0, 0},
                              { 0.338461548, 0, 0, 0} };
  float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11,r12,r13,r14,r15,r16;
  uint4 bitmask, uiDest;
  float4 fDest;

  r0.xyzw = t1.Sample(s1_s, v8.wz).xyzw;
  r0.x = r0.x + -r0.w;
  r0.xyz = float3(1,0,0) + r0.xyz;
  r0.xyz = r0.xyz * float3(2,2,2) + float3(-1,-1,-1);
  r1.x = dot(v5.xyz, r0.xyz);
  r1.y = dot(v11.xyz, r0.xyz);
  r1.z = dot(v3.xyz, r0.xyz);
  r0.x = dot(r1.xyz, r1.xyz);
  r0.x = rsqrt(r0.x);
  r0.yzw = r1.xyz * r0.xxx;
  r2.x = v5.w;
  r2.y = v11.w;
  r2.z = v3.w;
  r1.x = dot(-r2.xyz, -r2.xyz);
  r1.x = rsqrt(r1.x);
  r3.xyz = -r2.xyz * r1.xxx;
  r4.xyz = -r2.xyz * r1.xxx + cb0[2].xyz;
  r1.z = dot(r4.xyz, r4.xyz);
  r1.z = rsqrt(r1.z);
  r4.xyz = r4.xyz * r1.zzz;
  r1.zw = t5.Sample(s5_s, v10.wz).yz;
  r1.w = cb5[6].w * r1.w;
  r2.w = dot(-r3.xyz, r0.yzw);
  r2.w = r2.w + r2.w;
  r3.xyz = r0.yzw * -r2.www + -r3.xyz;
  r5.xy = r3.xy * float2(0.5,-0.5) + float2(0.5,0.5);
  r2.w = saturate(0.00100000005 * r1.w);
  r2.w = 1 + -r2.w;
  r2.w = log2(r2.w);
  r2.w = 10 * r2.w;
  r2.w = exp2(r2.w);
  r2.w = 8 * r2.w;
  r5.xyzw = t7.SampleLevel(s7_s, r5.xy, r2.w).xyzw;
  r2.w = 1 + -r5.w;
  r2.w = 4 * r2.w;
  r2.w = exp2(r2.w);
  r5.xyz = r5.xyz * r2.www;
  r5.xyz = cb1[2].xyz * r5.xyz;
  r3.x = dot(r0.yzw, r3.xyz);
  r3.y = 0.5;
  r2.w = t6.Sample(s6_s, r3.xy).w;
  r3.x = r2.w * r1.z;
  r6.xyzw = t4.Sample(s4_s, v10.xy).xyzw;
  r3.y = log2(r6.w);
  r3.y = 2.20000005 * r3.y;
  r3.y = exp2(r3.y);
  r3.z = r6.y + -r3.y;
  r3.y = r6.x * r3.z + r3.y;
  r3.z = r6.z + -r6.y;
  r3.z = r6.x * r3.z + r6.y;
  r3.w = dot(r0.yzw, cb0[2].xyz);
  r4.x = dot(r0.yzw, r4.xyz);
  r4.y = cmp(r3.w >= 0);
  r4.z = max(0, r3.w);
  r4.w = cmp(r4.x >= 0);
  r4.y = r4.y ? r4.w : 0;
  r4.x = log2(r4.x);
  r4.x = r4.x * r1.w;
  r4.x = exp2(r4.x);
  r4.x = r4.y ? r4.x : 0;
  r4.x = min(1, r4.x);
  r3.w = max(0, -r3.w);
  r0.x = saturate(r1.y * r0.x + 1);
  r1.y = saturate(r0.z);
  r6.xyz = -cb5[9].xyz + cb5[1].xyz;
  r6.xyz = r1.yyy * r6.xyz + cb5[9].xyz;
  r7.xyz = cb5[9].xyz + -cb5[2].xyz;
  r7.xyz = r0.xxx * r7.xyz + cb5[2].xyz;
  r0.x = cmp(0 < r0.z);
  r1.y = cmp(r0.z < 0);
  r0.x = (int)r1.y + (int)-r0.x;
  r0.x = (int)r0.x;
  r0.x = saturate(r0.x);
  r6.xyz = -r7.xyz + r6.xyz;
  r6.xyz = r0.xxx * r6.xyz + r7.xyz;
  r6.xyz = cb5[8].xyz + r6.xyz;
  r6.xyz = cb5[5].xyz * r3.www + r6.xyz;
  r6.xyz = r6.xyz * r3.yyy + v1.xyz;
  r4.yzw = cb5[4].xyz * r4.zzz;
  r0.x = -r2.w * r1.z + 1;
  r4.yzw = r4.yzw * r0.xxx + cb5[3].xyz;
  r7.xyz = cb5[6].xyz * r4.xxx;
  r7.xyz = r7.xyz * r3.xxx;
  r5.xyz = cb6[0].xyz * r5.xyz;
  r5.xyz = r5.xyz * r3.xxx;
  r5.xyz = r5.xyz + r5.xyz;
  r8.x = 1;
  r9.xyz = float3(0,0,0);
  r10.xyz = float3(0,0,0);
  r11.xyz = float3(0,0,0);
  r0.x = 0;
  while (true) {
    r1.y = cmp((int)r0.x >= asint(cb10[0].x));
    if (r1.y != 0) break;
    r1.y = (int)r0.x * 6;
    r12.xyz = cb11[r1.y+0].xyz + -r2.xyz;
    r1.y = dot(r12.xyz, r12.xyz);
    r1.y = sqrt(r1.y);
    r1.z = 9.99999975e-005 + r1.y;
    r12.xyz = r12.xyz / r1.zzz;
    r13.xyzw = mad((int4)r0.xxxx, int4(6,6,6,6), int4(4,5,2,3));
    r1.z = r1.y * cb10[2].x + -cb11[r13.x+0].x;
    r8.y = max(0, r1.z);
    r8.z = r8.y * r8.y;
    r1.z = dot(cb11[r13.x+0].yzw, r8.xyz);
    r1.z = 9.99999975e-005 + r1.z;
    r1.z = 1 / r1.z;
    r1.z = saturate(r1.z);
    r1.y = r1.y * cb10[2].x + -cb11[r13.y+0].x;
    r1.y = saturate(cb11[r13.y+0].y * r1.y);
    r1.y = 1 + -r1.y;
    r1.y = r1.z * r1.y;
    r8.yzw = -r2.xyz * r1.xxx + r12.xyz;
    r1.z = dot(r8.yzw, r8.yzw);
    r1.z = rsqrt(r1.z);
    r8.yzw = r8.yzw * r1.zzz;
    r1.z = dot(r0.yzw, r12.xyz);
    r2.w = dot(r0.yzw, r8.yzw);
    r3.y = cmp(r1.z >= 0);
    r1.z = max(0, r1.z);
    r3.w = cmp(r2.w >= 0);
    r3.y = r3.y ? r3.w : 0;
    r2.w = log2(r2.w);
    r2.w = r2.w * r1.w;
    r2.w = exp2(r2.w);
    r2.w = r3.y ? r2.w : 0;
    r2.w = min(1, r2.w);
    r8.yzw = cb11[r13.z+0].xyz * cb10[3].xyz;
    r8.yzw = r8.yzw * r1.zzz;
    r9.xyz = r8.yzw * r1.yyy + r9.xyz;
    r10.xyz = cb11[r13.w+0].xyz * r1.yyy + r10.xyz;
    r8.yzw = cb11[r13.z+0].xyz * cb5[7].xyz;
    r1.z = r3.x * r2.w;
    r8.yzw = r1.zzz * r8.yzw;
    r11.xyz = r8.yzw * r1.yyy + r11.xyz;
    r0.x = (int)r0.x + 1;
  }
  r1.y = asint(cb10[0].x) + asint(cb10[1].x);
  r8.x = 1;
  r12.xyz = r9.xyz;
  r13.xyz = r10.xyz;
  r14.xyz = r11.xyz;
  r1.z = r0.x;
  while (true) {
    r2.w = cmp((int)r1.z >= (int)r1.y);
    if (r2.w != 0) break;
    r2.w = (int)r1.z * 6;
    r15.xyz = cb11[r2.w+0].xyz + -r2.xyz;
    r2.w = dot(r15.xyz, r15.xyz);
    r2.w = sqrt(r2.w);
    r3.y = 9.99999975e-005 + r2.w;
    r15.xyz = r15.xyz / r3.yyy;
    r3.y = mad((int)r1.z, 6, 1);
    r3.w = dot(-cb11[r3.y+0].xyz, r15.xyz);
    r3.y = -cb11[r3.y+0].w + r3.w;
    r16.xyzw = mad((int4)r1.zzzz, int4(6,6,6,6), int4(2,3,4,5));
    r3.y = saturate(cb11[r16.x+0].w * r3.y);
    r3.y = log2(r3.y);
    r3.y = cb11[r16.y+0].w * r3.y;
    r3.y = exp2(r3.y);
    r3.w = r2.w * cb10[2].x + -cb11[r16.z+0].x;
    r8.y = max(0, r3.w);
    r8.z = r8.y * r8.y;
    r3.w = dot(cb11[r16.z+0].yzw, r8.xyz);
    r3.w = 9.99999975e-005 + r3.w;
    r3.w = 1 / r3.w;
    r3.w = saturate(r3.w);
    r2.w = r2.w * cb10[2].x + -cb11[r16.w+0].x;
    r2.w = saturate(cb11[r16.w+0].y * r2.w);
    r2.w = 1 + -r2.w;
    r2.w = r3.w * r2.w;
    r2.w = r2.w * r3.y;
    r8.yzw = -r2.xyz * r1.xxx + r15.xyz;
    r3.y = dot(r8.yzw, r8.yzw);
    r3.y = rsqrt(r3.y);
    r8.yzw = r8.yzw * r3.yyy;
    r3.y = dot(r0.yzw, r15.xyz);
    r3.w = dot(r0.yzw, r8.yzw);
    r4.x = cmp(r3.y >= 0);
    r3.y = max(0, r3.y);
    r5.w = cmp(r3.w >= 0);
    r4.x = r4.x ? r5.w : 0;
    r3.w = log2(r3.w);
    r3.w = r3.w * r1.w;
    r3.w = exp2(r3.w);
    r3.w = r4.x ? r3.w : 0;
    r3.w = min(1, r3.w);
    r8.yzw = cb11[r16.x+0].xyz * cb10[3].xyz;
    r8.yzw = r8.yzw * r3.yyy;
    r12.xyz = r8.yzw * r2.www + r12.xyz;
    r13.xyz = cb11[r16.y+0].xyz * r2.www + r13.xyz;
    r8.yzw = cb11[r16.x+0].xyz * cb5[7].xyz;
    r3.y = r3.x * r3.w;
    r8.yzw = r3.yyy * r8.yzw;
    r14.xyz = r8.yzw * r2.www + r14.xyz;
    r1.z = (int)r1.z + 1;
  }
  r0.xyz = r13.xyz + r12.xyz;
  r1.xyzw = t0.Sample(s0_s, v8.xy).xyzw;
  r2.xyzw = cb6[1].xyzw * r1.xyzw;
  r3.xyw = t2.Sample(s2_s, v9.xy).xyz;
  r8.xyzw = t3.Sample(s3_s, v9.wz).xyzw;
  r1.xyz = -r1.xyz * cb6[1].xyz + r8.xyz;
  r1.xyz = r8.www * r1.xyz + r2.xyz;
  r1.xyz = r1.xyz * r3.xyw;
  r1.xyz = r1.xyz + r1.xyz;
  r0.w = saturate(v1.w * r2.w);
  r2.xy = cmp(float2(0,0) < cb6[4].xz);
  r1.w = -cb6[4].y + r0.w;
  r1.w = cmp(r1.w < 0);
  r1.w = r2.x ? r1.w : 0;
  if (r1.w != 0) discard;
  r0.w = max(cb5[0].w, r0.w);
  if (r2.y != 0) {
    r2.xy = (int2)v0.yx;
    r2.zw = (int2)r2.xy & int2(0,0);
    r2.xy = max((int2)-r2.xy, (int2)r2.xy);
    r2.xy = (int2)r2.xy & int2(7,7);
    r3.xy = -(int2)r2.xy;
    r2.xy = r2.zw ? r3.xy : r2.xy;
    r1.w = (uint)r2.y << 3;
    r1.w = (int)r1.w + (int)r2.x;
    r2.x = cmp(0 < w7.x);
    r2.y = cmp(w7.x < 0);
    r2.x = (int)r2.y + (int)-r2.x;
    r2.x = (int)r2.x;
    r1.w = -icb[r1.w+0].x + w7.x;
    r2.y = -1 + r2.x;
    r2.y = 0.5 * r2.y;
    r1.w = r2.x * r1.w + r2.y;
    r1.w = cmp(r1.w < 0);
    if (r1.w != 0) discard;
  }
  r1.w = cb5[12].z + -v6.w;
  r1.w = max(0, r1.w);
  r2.xyz = cb0[15].xyz * -r1.www;
  r2.xyz = float3(1.44269502,1.44269502,1.44269502) * r2.xyz;
  r2.xyz = exp2(r2.xyz);
  r3.xyw = cb0[16].xyz * -r1.www;
  r3.xyw = float3(1.44269502,1.44269502,1.44269502) * r3.xyw;
  r3.xyw = exp2(r3.xyw);
  r4.xyz = r4.yzw * r3.xyw;
  r6.xyz = r6.xyz * r2.xyz;
  r3.xyw = r7.xyz * r3.xyw;
  r7.xy = cb0[12].xy * v0.xy;
  r7.xy = (int2)r7.xy;
  r7.zw = float2(0,0);
  r7.xyzw = t16.Load(r7.xyz).xyzw;
  r8.xyz = cb0[10].www * r4.xyz;
  r7.yzw = r8.xyz * r7.yzw;
  r1.w = -1 + r7.x;
  r1.w = r0.w * r1.w + 1;
  r4.xyz = r7.yzw * r0.www + r4.xyz;
  r0.xyz = r6.xyz * r1.www + r0.xyz;
  r2.xyz = r5.xyz * r2.xyz + r14.xyz;
  r1.w = -r3.z * v2.w + 1;
  r1.w = saturate(1 + -r1.w);
  r0.xyz = r4.xyz * r1.www + r0.xyz;
  r0.xyz = r0.xyz * r1.xyz;
  r1.xyz = r3.xyw * r1.www + r2.xyz;
  r0.xyz = r0.xyz * r0.www + r1.xyz;
  switch (cb5[11].x) {
    case 1 :    case 3 :    r1.y = cb5[13].y + cb5[12].z;
    r2.xyz = cb6[9].xyz + -v6.xyz;
    r1.z = dot(r2.xyz, r2.xyz);
    r1.z = sqrt(r1.z);
    r1.w = cmp(cb6[9].y < r1.y);
    if (r1.w != 0) {
      r2.x = -cb6[9].y + v6.y;
      r2.x = max(0, r2.x);
      r2.x = 9.99999975e-006 + r2.x;
      r2.y = -cb6[9].y + r1.y;
      r2.x = saturate(r2.y / r2.x);
      r2.y = r2.x * r1.z;
      r2.z = -r1.z * r2.x + r1.z;
      r2.w = cmp(0 < r2.z);
      if (r2.w != 0) {
        r2.x = 1 + -r2.x;
        r2.x = r2.x * r1.z;
        r2.w = v6.y + -r1.y;
        r3.x = 9.99999975e-006 + r2.z;
        r3.y = abs(r2.w) / r3.x;
        r3.y = cb5[10].x * r3.y;
        r3.z = cmp(r3.y == 0.000000);
        r3.w = -r3.y * r2.x;
        r3.w = 1.44269502 * r3.w;
        r3.w = exp2(r3.w);
        r3.w = 1 + -r3.w;
        r3.y = r3.w / r3.y;
        r3.y = r3.z ? r2.x : r3.y;
        r3.z = min(v6.y, r1.y);
        r3.z = -cb5[10].x * r3.z;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = -cb5[10].y * r3.z;
        r3.y = r3.z * r3.y;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = min(1, r3.y);
        r2.w = r2.w / r3.x;
        r2.w = cb0[14].z * r2.w;
        r3.x = cmp(r2.w == 0.000000);
        r3.z = -r2.w * r2.x;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = 1 + -r3.z;
        r2.w = r3.z / r2.w;
        r2.x = r3.x ? r2.x : r2.w;
        r2.w = -cb0[14].x + r1.y;
        r2.w = -cb0[14].z * r2.w;
        r2.w = 1.44269502 * r2.w;
        r2.w = exp2(r2.w);
        r2.w = -cb0[14].y * r2.w;
        r2.x = r2.w * r2.x;
        r2.x = 1.44269502 * r2.x;
        r2.x = exp2(r2.x);
        r2.x = min(1, r2.x);
        r2.x = r3.y * r2.x;
      } else {
        r2.x = 1;
      }
      r2.y = -cb5[12].w * r2.y;
      r2.y = 1.44269502 * r2.y;
      r2.y = exp2(r2.y);
      r2.y = min(1, r2.y);
    } else {
      r2.w = cb6[9].y + -v6.y;
      r2.w = max(0, r2.w);
      r2.w = 9.99999975e-006 + r2.w;
      r3.x = cb6[9].y + -r1.y;
      r2.w = saturate(r3.x / r2.w);
      r2.z = r2.w * r1.z;
      r3.x = -r1.z * r2.w + r1.z;
      r1.y = max(v6.y, r1.y);
      r3.y = -cb6[9].y + r1.y;
      r1.z = r1.z * r2.w + 9.99999975e-006;
      r2.w = abs(r3.y) / r1.z;
      r2.w = cb5[10].x * r2.w;
      r3.z = cmp(r2.w == 0.000000);
      r3.w = -r2.w * r2.z;
      r3.w = 1.44269502 * r3.w;
      r3.w = exp2(r3.w);
      r3.w = 1 + -r3.w;
      r2.w = r3.w / r2.w;
      r2.w = r3.z ? r2.z : r2.w;
      r1.y = min(cb6[9].y, r1.y);
      r1.y = -cb5[10].x * r1.y;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.y = -cb5[10].y * r1.y;
      r1.y = r1.y * r2.w;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.z = r3.y / r1.z;
      r1.z = cb0[14].z * r1.z;
      r2.w = cmp(r1.z == 0.000000);
      r3.y = -r1.z * r2.z;
      r3.y = 1.44269502 * r3.y;
      r3.y = exp2(r3.y);
      r3.y = 1 + -r3.y;
      r1.z = r3.y / r1.z;
      r1.z = r2.w ? r2.z : r1.z;
      r2.w = cb6[9].y + -cb0[14].x;
      r2.w = -cb0[14].z * r2.w;
      r2.w = 1.44269502 * r2.w;
      r2.w = exp2(r2.w);
      r2.w = -cb0[14].y * r2.w;
      r1.z = r2.w * r1.z;
      r1.z = 1.44269502 * r1.z;
      r1.z = exp2(r1.z);
      r1.yz = min(float2(1,1), r1.yz);
      r2.x = r1.y * r1.z;
      r1.y = -cb5[12].w * r3.x;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r2.y = min(1, r1.y);
    }
    r1.y = cb5[12].x + -r2.z;
    r1.y = saturate(cb5[12].y * r1.y);
    r1.z = r2.x * r1.y;
    r3.xyz = -cb6[9].xyz + v6.xyz;
    r2.z = dot(r3.xyz, r3.xyz);
    r2.z = rsqrt(r2.z);
    r2.w = r3.y * r2.z;
    r3.x = cmp(r2.w < 0);
    r2.z = r3.y * r2.z + 1;
    r2.z = r2.z * r2.z;
    r3.yz = cb0[17].yz + -cb0[17].xy;
    r2.z = r2.z * r3.y + cb0[17].x;
    r2.w = r2.w * r3.z + cb0[17].y;
    r2.z = r3.x ? r2.z : r2.w;
    r3.xyz = cb0[7].xyz * r2.zzz;
    r3.xyz = r3.xyz * r0.www;
    r4.xyz = cb0[1].xyz * r0.www;
    r5.x = -r2.x * r1.y + 1;
    r6.x = r5.x * r2.y;
    r6.y = 1 + -r2.y;
    r6.z = r1.z * r2.y;
    r5.y = r6.y * r1.z;
    r5.z = r6.z;
    r1.yzw = r1.www ? r6.xyz : r5.xyz;
    r2.xyz = r3.xyz * r1.zzz;
    r2.xyz = r4.xyz * r1.yyy + r2.xyz;
    r0.xyz = r0.xyz * r1.www + r2.xyz;
    r1.x = 1;
    break;
    case 2 :    r1.y = cb5[13].y + cb5[12].z;
    r2.xyz = cb6[9].xyz + -v6.xyz;
    r1.z = dot(r2.xyz, r2.xyz);
    r1.z = sqrt(r1.z);
    r1.w = cmp(cb6[9].y < r1.y);
    if (r1.w != 0) {
      r1.w = -cb6[9].y + v6.y;
      r1.w = max(0, r1.w);
      r1.w = 9.99999975e-006 + r1.w;
      r2.x = -cb6[9].y + r1.y;
      r1.w = saturate(r2.x / r1.w);
      r2.x = r1.z * r1.w;
      r2.y = -r1.z * r1.w + r1.z;
      r2.z = cmp(0 < r2.y);
      if (r2.z != 0) {
        r1.w = 1 + -r1.w;
        r1.w = r1.z * r1.w;
        r2.z = v6.y + -r1.y;
        r2.w = 9.99999975e-006 + r2.y;
        r3.x = abs(r2.z) / r2.w;
        r3.x = cb5[10].x * r3.x;
        r3.y = cmp(r3.x == 0.000000);
        r3.z = -r3.x * r1.w;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = 1 + -r3.z;
        r3.x = r3.z / r3.x;
        r3.x = r3.y ? r1.w : r3.x;
        r3.y = min(v6.y, r1.y);
        r3.y = -cb5[10].x * r3.y;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = -cb5[10].y * r3.y;
        r3.x = r3.y * r3.x;
        r3.x = 1.44269502 * r3.x;
        r3.x = exp2(r3.x);
        r3.x = min(1, r3.x);
        r2.z = r2.z / r2.w;
        r2.z = cb0[14].z * r2.z;
        r2.w = cmp(r2.z == 0.000000);
        r3.y = -r2.z * r1.w;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = 1 + -r3.y;
        r2.z = r3.y / r2.z;
        r1.w = r2.w ? r1.w : r2.z;
        r2.z = -cb0[14].x + r1.y;
        r2.z = -cb0[14].z * r2.z;
        r2.z = 1.44269502 * r2.z;
        r2.z = exp2(r2.z);
        r2.z = -cb0[14].y * r2.z;
        r1.w = r2.z * r1.w;
        r1.w = 1.44269502 * r1.w;
        r1.w = exp2(r1.w);
        r1.w = min(1, r1.w);
        r3.x = r3.x * r1.w;
      } else {
        r3.x = 1;
      }
      r1.w = -cb5[12].w * r2.x;
      r1.w = 1.44269502 * r1.w;
      r1.w = exp2(r1.w);
      r3.y = min(1, r1.w);
    } else {
      r1.w = cb6[9].y + -v6.y;
      r1.w = max(0, r1.w);
      r1.w = 9.99999975e-006 + r1.w;
      r2.x = cb6[9].y + -r1.y;
      r1.w = saturate(r2.x / r1.w);
      r2.y = r1.z * r1.w;
      r2.x = -r1.z * r1.w + r1.z;
      r1.y = max(v6.y, r1.y);
      r2.z = -cb6[9].y + r1.y;
      r1.z = r1.z * r1.w + 9.99999975e-006;
      r1.w = abs(r2.z) / r1.z;
      r1.w = cb5[10].x * r1.w;
      r2.w = cmp(r1.w == 0.000000);
      r3.z = -r1.w * r2.y;
      r3.z = 1.44269502 * r3.z;
      r3.z = exp2(r3.z);
      r3.z = 1 + -r3.z;
      r1.w = r3.z / r1.w;
      r1.w = r2.w ? r2.y : r1.w;
      r1.y = min(cb6[9].y, r1.y);
      r1.y = -cb5[10].x * r1.y;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.y = -cb5[10].y * r1.y;
      r1.y = r1.y * r1.w;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.z = r2.z / r1.z;
      r1.z = cb0[14].z * r1.z;
      r1.w = cmp(r1.z == 0.000000);
      r2.z = -r1.z * r2.y;
      r2.z = 1.44269502 * r2.z;
      r2.z = exp2(r2.z);
      r2.z = 1 + -r2.z;
      r1.z = r2.z / r1.z;
      r1.z = r1.w ? r2.y : r1.z;
      r1.w = cb6[9].y + -cb0[14].x;
      r1.w = -cb0[14].z * r1.w;
      r1.w = 1.44269502 * r1.w;
      r1.w = exp2(r1.w);
      r1.w = -cb0[14].y * r1.w;
      r1.z = r1.w * r1.z;
      r1.z = 1.44269502 * r1.z;
      r1.z = exp2(r1.z);
      r1.yz = min(float2(1,1), r1.yz);
      r3.x = r1.y * r1.z;
      r1.y = -cb5[12].w * r2.x;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r3.y = min(1, r1.y);
    }
    r1.y = cb5[12].x + -r2.y;
    r1.y = saturate(cb5[12].y * r1.y);
    r1.y = r3.x * r1.y;
    r1.x = r1.y * r3.y;
    break;
    default :
    r1.x = 1;
    break;
  }
  o0.xyzw = r1.xxxx * r0.xyzw;
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.2.67 on Fri Dec 01 18:49:09 2017
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float   xy  
// TEXCOORD                 6   xyzw        1     NONE   float   xyzw
// TEXCOORD                 7   xyzw        2     NONE   float      w
// TEXCOORD                 4   xyzw        3     NONE   float   xyzw
// TEXCOORD                 5   xyzw        4     NONE   float       
// COLOR                    0   xyzw        5     NONE   float   xyzw
// COLOR                    1   xyzw        6     NONE   float   xyzw
// TEXCOORD                10   xyz         7     NONE   float       
// TEXCOORD                11      w        7     NONE   float      w
// TEXCOORD                 0   xyzw        8     NONE   float   xyzw
// TEXCOORD                 1   xyzw        9     NONE   float   xyzw
// TEXCOORD                 2   xyzw       10     NONE   float   xyzw
// TEXCOORD                 3   xyzw       11     NONE   float   xyzw
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_Target                0   xyzw        0   TARGET   float   xyzw
//
ps_5_0
dcl_globalFlags refactoringAllowed
dcl_immediateConstantBuffer { { 0.0153846154, 0, 0, 0},
                              { 0.753846169, 0, 0, 0},
                              { 0.200000, 0, 0, 0},
                              { 0.938461542, 0, 0, 0},
                              { 0.0615384616, 0, 0, 0},
                              { 0.800000, 0, 0, 0},
                              { 0.246153846, 0, 0, 0},
                              { 0.984615386, 0, 0, 0},
                              { 0.507692337, 0, 0, 0},
                              { 0.261538476, 0, 0, 0},
                              { 0.692307711, 0, 0, 0},
                              { 0.446153849, 0, 0, 0},
                              { 0.553846180, 0, 0, 0},
                              { 0.307692319, 0, 0, 0},
                              { 0.738461554, 0, 0, 0},
                              { 0.492307693, 0, 0, 0},
                              { 0.138461545, 0, 0, 0},
                              { 0.876923084, 0, 0, 0},
                              { 0.0769230798, 0, 0, 0},
                              { 0.815384626, 0, 0, 0},
                              { 0.184615389, 0, 0, 0},
                              { 0.923076928, 0, 0, 0},
                              { 0.123076923, 0, 0, 0},
                              { 0.861538470, 0, 0, 0},
                              { 0.630769253, 0, 0, 0},
                              { 0.384615391, 0, 0, 0},
                              { 0.569230795, 0, 0, 0},
                              { 0.323076934, 0, 0, 0},
                              { 0.676923096, 0, 0, 0},
                              { 0.430769235, 0, 0, 0},
                              { 0.615384638, 0, 0, 0},
                              { 0.369230777, 0, 0, 0},
                              { 0.0461538471, 0, 0, 0},
                              { 0.784615397, 0, 0, 0},
                              { 0.230769232, 0, 0, 0},
                              { 0.969230771, 0, 0, 0},
                              { 0.0307692308, 0, 0, 0},
                              { 0.769230783, 0, 0, 0},
                              { 0.215384617, 0, 0, 0},
                              { 0.953846157, 0, 0, 0},
                              { 0.538461566, 0, 0, 0},
                              { 0.292307705, 0, 0, 0},
                              { 0.723076940, 0, 0, 0},
                              { 0.476923078, 0, 0, 0},
                              { 0.523076952, 0, 0, 0},
                              { 0.276923090, 0, 0, 0},
                              { 0.707692325, 0, 0, 0},
                              { 0.461538464, 0, 0, 0},
                              { 0.169230774, 0, 0, 0},
                              { 0.907692313, 0, 0, 0},
                              { 0.107692309, 0, 0, 0},
                              { 0.846153855, 0, 0, 0},
                              { 0.153846160, 0, 0, 0},
                              { 0.892307699, 0, 0, 0},
                              { 0.0923076943, 0, 0, 0},
                              { 0.830769241, 0, 0, 0},
                              { 0.661538482, 0, 0, 0},
                              { 0.415384620, 0, 0, 0},
                              { 0.600000, 0, 0, 0},
                              { 0.353846163, 0, 0, 0},
                              { 0.646153867, 0, 0, 0},
                              { 0.400000, 0, 0, 0},
                              { 0.584615409, 0, 0, 0},
                              { 0.338461548, 0, 0, 0} }
dcl_constantbuffer cb0[18], immediateIndexed
dcl_constantbuffer cb1[3], immediateIndexed
dcl_constantbuffer cb5[14], immediateIndexed
dcl_constantbuffer cb6[10], immediateIndexed
dcl_constantbuffer cb10[4], immediateIndexed
dcl_constantbuffer cb11[192], dynamicIndexed
dcl_sampler s0, mode_default
dcl_sampler s1, mode_default
dcl_sampler s2, mode_default
dcl_sampler s3, mode_default
dcl_sampler s4, mode_default
dcl_sampler s5, mode_default
dcl_sampler s6, mode_default
dcl_sampler s7, mode_default
dcl_resource_texture2d (float,float,float,float) t0
dcl_resource_texture2d (float,float,float,float) t1
dcl_resource_texture2d (float,float,float,float) t2
dcl_resource_texture2d (float,float,float,float) t3
dcl_resource_texture2d (float,float,float,float) t4
dcl_resource_texture2d (float,float,float,float) t5
dcl_resource_texture2d (float,float,float,float) t6
dcl_resource_texture2d (float,float,float,float) t7
dcl_resource_texture2d (float,float,float,float) t16
dcl_input_ps_siv linear noperspective v0.xy, position
dcl_input_ps linear centroid v1.xyzw
dcl_input_ps linear centroid v2.w
dcl_input_ps linear centroid v3.xyzw
dcl_input_ps linear centroid v5.xyzw
dcl_input_ps linear centroid v6.xyzw
dcl_input_ps linear centroid v7.w
dcl_input_ps linear centroid v8.xyzw
dcl_input_ps linear centroid v9.xyzw
dcl_input_ps linear centroid v10.xyzw
dcl_input_ps linear centroid v11.xyzw
dcl_output o0.xyzw
dcl_temps 17
sample_indexable(texture2d)(float,float,float,float) r0.xyzw, v8.wzww, t1.xyzw, s1
add r0.x, -r0.w, r0.x
add r0.xyz, r0.xyzx, l(1.000000, 0.000000, 0.000000, 0.000000)
mad r0.xyz, r0.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(-1.000000, -1.000000, -1.000000, 0.000000)
dp3 r1.x, v5.xyzx, r0.xyzx
dp3 r1.y, v11.xyzx, r0.xyzx
dp3 r1.z, v3.xyzx, r0.xyzx
dp3 r0.x, r1.xyzx, r1.xyzx
rsq r0.x, r0.x
mul r0.yzw, r0.xxxx, r1.xxyz
mov r2.x, v5.w
mov r2.y, v11.w
mov r2.z, v3.w
dp3 r1.x, -r2.xyzx, -r2.xyzx
rsq r1.x, r1.x
mul r3.xyz, r1.xxxx, -r2.xyzx
mad r4.xyz, -r2.xyzx, r1.xxxx, cb0[2].xyzx
dp3 r1.z, r4.xyzx, r4.xyzx
rsq r1.z, r1.z
mul r4.xyz, r1.zzzz, r4.xyzx
sample_indexable(texture2d)(float,float,float,float) r1.zw, v10.wzww, t5.xwyz, s5
mul r1.w, r1.w, cb5[6].w
dp3 r2.w, -r3.xyzx, r0.yzwy
add r2.w, r2.w, r2.w
mad r3.xyz, r0.yzwy, -r2.wwww, -r3.xyzx
mad r5.xy, r3.xyxx, l(0.500000, -0.500000, 0.000000, 0.000000), l(0.500000, 0.500000, 0.000000, 0.000000)
mul_sat r2.w, r1.w, l(0.001000)
add r2.w, -r2.w, l(1.000000)
log r2.w, r2.w
mul r2.w, r2.w, l(10.000000)
exp r2.w, r2.w
mul r2.w, r2.w, l(8.000000)
sample_l_indexable(texture2d)(float,float,float,float) r5.xyzw, r5.xyxx, t7.xyzw, s7, r2.w
add r2.w, -r5.w, l(1.000000)
mul r2.w, r2.w, l(4.000000)
exp r2.w, r2.w
mul r5.xyz, r2.wwww, r5.xyzx
mul r5.xyz, r5.xyzx, cb1[2].xyzx
dp3 r3.x, r0.yzwy, r3.xyzx
mov r3.y, l(0.500000)
sample_indexable(texture2d)(float,float,float,float) r2.w, r3.xyxx, t6.xyzw, s6
mul r3.x, r1.z, r2.w
sample_indexable(texture2d)(float,float,float,float) r6.xyzw, v10.xyxx, t4.xyzw, s4
log r3.y, r6.w
mul r3.y, r3.y, l(2.200000)
exp r3.y, r3.y
add r3.z, -r3.y, r6.y
mad r3.y, r6.x, r3.z, r3.y
add r3.z, -r6.y, r6.z
mad r3.z, r6.x, r3.z, r6.y
dp3 r3.w, r0.yzwy, cb0[2].xyzx
dp3 r4.x, r0.yzwy, r4.xyzx
ge r4.y, r3.w, l(0.000000)
max r4.z, r3.w, l(0.000000)
ge r4.w, r4.x, l(0.000000)
and r4.y, r4.y, r4.w
log r4.x, r4.x
mul r4.x, r1.w, r4.x
exp r4.x, r4.x
and r4.x, r4.x, r4.y
min r4.x, r4.x, l(1.000000)
max r3.w, -r3.w, l(0.000000)
mad_sat r0.x, r1.y, r0.x, l(1.000000)
mov_sat r1.y, r0.z
add r6.xyz, cb5[1].xyzx, -cb5[9].xyzx
mad r6.xyz, r1.yyyy, r6.xyzx, cb5[9].xyzx
add r7.xyz, -cb5[2].xyzx, cb5[9].xyzx
mad r7.xyz, r0.xxxx, r7.xyzx, cb5[2].xyzx
lt r0.x, l(0.000000), r0.z
lt r1.y, r0.z, l(0.000000)
iadd r0.x, r1.y, -r0.x
itof r0.x, r0.x
mov_sat r0.x, r0.x
add r6.xyz, r6.xyzx, -r7.xyzx
mad r6.xyz, r0.xxxx, r6.xyzx, r7.xyzx
add r6.xyz, r6.xyzx, cb5[8].xyzx
mad r6.xyz, cb5[5].xyzx, r3.wwww, r6.xyzx
mad r6.xyz, r6.xyzx, r3.yyyy, v1.xyzx
mul r4.yzw, r4.zzzz, cb5[4].xxyz
mad r0.x, -r2.w, r1.z, l(1.000000)
mad r4.yzw, r4.yyzw, r0.xxxx, cb5[3].xxyz
mul r7.xyz, r4.xxxx, cb5[6].xyzx
mul r7.xyz, r3.xxxx, r7.xyzx
mul r5.xyz, r5.xyzx, cb6[0].xyzx
mul r5.xyz, r3.xxxx, r5.xyzx
add r5.xyz, r5.xyzx, r5.xyzx
mov r8.x, l(1.000000)
mov r9.xyz, l(0,0,0,0)
mov r10.xyz, l(0,0,0,0)
mov r11.xyz, l(0,0,0,0)
mov r0.x, l(0)
loop 
  ige r1.y, r0.x, cb10[0].x
  breakc_nz r1.y
  imul null, r1.y, r0.x, l(6)
  add r12.xyz, -r2.xyzx, cb11[r1.y + 0].xyzx
  dp3 r1.y, r12.xyzx, r12.xyzx
  sqrt r1.y, r1.y
  add r1.z, r1.y, l(0.000100)
  div r12.xyz, r12.xyzx, r1.zzzz
  imad r13.xyzw, r0.xxxx, l(6, 6, 6, 6), l(4, 5, 2, 3)
  mad r1.z, r1.y, cb10[2].x, -cb11[r13.x + 0].x
  max r8.y, r1.z, l(0.000000)
  mul r8.z, r8.y, r8.y
  dp3 r1.z, cb11[r13.x + 0].yzwy, r8.xyzx
  add r1.z, r1.z, l(0.000100)
  div r1.z, l(1.000000, 1.000000, 1.000000, 1.000000), r1.z
  mov_sat r1.z, r1.z
  mad r1.y, r1.y, cb10[2].x, -cb11[r13.y + 0].x
  mul_sat r1.y, r1.y, cb11[r13.y + 0].y
  add r1.y, -r1.y, l(1.000000)
  mul r1.y, r1.y, r1.z
  mad r8.yzw, -r2.xxyz, r1.xxxx, r12.xxyz
  dp3 r1.z, r8.yzwy, r8.yzwy
  rsq r1.z, r1.z
  mul r8.yzw, r1.zzzz, r8.yyzw
  dp3 r1.z, r0.yzwy, r12.xyzx
  dp3 r2.w, r0.yzwy, r8.yzwy
  ge r3.y, r1.z, l(0.000000)
  max r1.z, r1.z, l(0.000000)
  ge r3.w, r2.w, l(0.000000)
  and r3.y, r3.y, r3.w
  log r2.w, r2.w
  mul r2.w, r1.w, r2.w
  exp r2.w, r2.w
  and r2.w, r2.w, r3.y
  min r2.w, r2.w, l(1.000000)
  mul r8.yzw, cb10[3].xxyz, cb11[r13.z + 0].xxyz
  mul r8.yzw, r1.zzzz, r8.yyzw
  mad r9.xyz, r8.yzwy, r1.yyyy, r9.xyzx
  mad r10.xyz, cb11[r13.w + 0].xyzx, r1.yyyy, r10.xyzx
  mul r8.yzw, cb5[7].xxyz, cb11[r13.z + 0].xxyz
  mul r1.z, r2.w, r3.x
  mul r8.yzw, r8.yyzw, r1.zzzz
  mad r11.xyz, r8.yzwy, r1.yyyy, r11.xyzx
  iadd r0.x, r0.x, l(1)
endloop 
iadd r1.y, cb10[0].x, cb10[1].x
mov r8.x, l(1.000000)
mov r12.xyz, r9.xyzx
mov r13.xyz, r10.xyzx
mov r14.xyz, r11.xyzx
mov r1.z, r0.x
loop 
  ige r2.w, r1.z, r1.y
  breakc_nz r2.w
  imul null, r2.w, r1.z, l(6)
  add r15.xyz, -r2.xyzx, cb11[r2.w + 0].xyzx
  dp3 r2.w, r15.xyzx, r15.xyzx
  sqrt r2.w, r2.w
  add r3.y, r2.w, l(0.000100)
  div r15.xyz, r15.xyzx, r3.yyyy
  imad r3.y, r1.z, l(6), l(1)
  dp3 r3.w, -cb11[r3.y + 0].xyzx, r15.xyzx
  add r3.y, r3.w, -cb11[r3.y + 0].w
  imad r16.xyzw, r1.zzzz, l(6, 6, 6, 6), l(2, 3, 4, 5)
  mul_sat r3.y, r3.y, cb11[r16.x + 0].w
  log r3.y, r3.y
  mul r3.y, r3.y, cb11[r16.y + 0].w
  exp r3.y, r3.y
  mad r3.w, r2.w, cb10[2].x, -cb11[r16.z + 0].x
  max r8.y, r3.w, l(0.000000)
  mul r8.z, r8.y, r8.y
  dp3 r3.w, cb11[r16.z + 0].yzwy, r8.xyzx
  add r3.w, r3.w, l(0.000100)
  div r3.w, l(1.000000, 1.000000, 1.000000, 1.000000), r3.w
  mov_sat r3.w, r3.w
  mad r2.w, r2.w, cb10[2].x, -cb11[r16.w + 0].x
  mul_sat r2.w, r2.w, cb11[r16.w + 0].y
  add r2.w, -r2.w, l(1.000000)
  mul r2.w, r2.w, r3.w
  mul r2.w, r3.y, r2.w
  mad r8.yzw, -r2.xxyz, r1.xxxx, r15.xxyz
  dp3 r3.y, r8.yzwy, r8.yzwy
  rsq r3.y, r3.y
  mul r8.yzw, r3.yyyy, r8.yyzw
  dp3 r3.y, r0.yzwy, r15.xyzx
  dp3 r3.w, r0.yzwy, r8.yzwy
  ge r4.x, r3.y, l(0.000000)
  max r3.y, r3.y, l(0.000000)
  ge r5.w, r3.w, l(0.000000)
  and r4.x, r4.x, r5.w
  log r3.w, r3.w
  mul r3.w, r1.w, r3.w
  exp r3.w, r3.w
  and r3.w, r3.w, r4.x
  min r3.w, r3.w, l(1.000000)
  mul r8.yzw, cb10[3].xxyz, cb11[r16.x + 0].xxyz
  mul r8.yzw, r3.yyyy, r8.yyzw
  mad r12.xyz, r8.yzwy, r2.wwww, r12.xyzx
  mad r13.xyz, cb11[r16.y + 0].xyzx, r2.wwww, r13.xyzx
  mul r8.yzw, cb5[7].xxyz, cb11[r16.x + 0].xxyz
  mul r3.y, r3.w, r3.x
  mul r8.yzw, r8.yyzw, r3.yyyy
  mad r14.xyz, r8.yzwy, r2.wwww, r14.xyzx
  iadd r1.z, r1.z, l(1)
endloop 
add r0.xyz, r12.xyzx, r13.xyzx
sample_indexable(texture2d)(float,float,float,float) r1.xyzw, v8.xyxx, t0.xyzw, s0
mul r2.xyzw, r1.xyzw, cb6[1].xyzw
sample_indexable(texture2d)(float,float,float,float) r3.xyw, v9.xyxx, t2.xywz, s2
sample_indexable(texture2d)(float,float,float,float) r8.xyzw, v9.wzww, t3.xyzw, s3
mad r1.xyz, -r1.xyzx, cb6[1].xyzx, r8.xyzx
mad r1.xyz, r8.wwww, r1.xyzx, r2.xyzx
mul r1.xyz, r3.xywx, r1.xyzx
add r1.xyz, r1.xyzx, r1.xyzx
mul_sat r0.w, r2.w, v1.w
lt r2.xy, l(0.000000, 0.000000, 0.000000, 0.000000), cb6[4].xzxx
add r1.w, r0.w, -cb6[4].y
lt r1.w, r1.w, l(0.000000)
and r1.w, r2.x, r1.w
discard_nz r1.w
max r0.w, r0.w, cb5[0].w
if_nz r2.y
  ftoi r2.xy, v0.yxyy
  and r2.zw, r2.xxxy, l(0, 0, 0x80000000, 0x80000000)
  imax r2.xy, r2.xyxx, -r2.xyxx
  and r2.xy, r2.xyxx, l(7, 7, 0, 0)
  ineg r3.xy, r2.xyxx
  movc r2.xy, r2.zwzz, r3.xyxx, r2.xyxx
  ishl r1.w, r2.y, l(3)
  iadd r1.w, r1.w, r2.x
  lt r2.x, l(0.000000), v7.w
  lt r2.y, v7.w, l(0.000000)
  iadd r2.x, r2.y, -r2.x
  itof r2.x, r2.x
  add r1.w, v7.w, -icb[r1.w + 0].x
  add r2.y, r2.x, l(-1.000000)
  mul r2.y, r2.y, l(0.500000)
  mad r1.w, r2.x, r1.w, r2.y
  lt r1.w, r1.w, l(0.000000)
  discard_nz r1.w
endif 
add r1.w, -v6.w, cb5[12].z
max r1.w, r1.w, l(0.000000)
mul r2.xyz, -r1.wwww, cb0[15].xyzx
mul r2.xyz, r2.xyzx, l(1.442695, 1.442695, 1.442695, 0.000000)
exp r2.xyz, r2.xyzx
mul r3.xyw, -r1.wwww, cb0[16].xyxz
mul r3.xyw, r3.xyxw, l(1.442695, 1.442695, 0.000000, 1.442695)
exp r3.xyw, r3.xyxw
mul r4.xyz, r3.xywx, r4.yzwy
mul r6.xyz, r2.xyzx, r6.xyzx
mul r3.xyw, r3.xyxw, r7.xyxz
mul r7.xy, v0.xyxx, cb0[12].xyxx
ftoi r7.xy, r7.xyxx
mov r7.zw, l(0,0,0,0)
ld_indexable(texture2d)(float,float,float,float) r7.xyzw, r7.xyzw, t16.xyzw
mul r8.xyz, r4.xyzx, cb0[10].wwww
mul r7.yzw, r7.yyzw, r8.xxyz
add r1.w, r7.x, l(-1.000000)
mad r1.w, r0.w, r1.w, l(1.000000)
mad r4.xyz, r7.yzwy, r0.wwww, r4.xyzx
mad r0.xyz, r6.xyzx, r1.wwww, r0.xyzx
mad r2.xyz, r5.xyzx, r2.xyzx, r14.xyzx
mad r1.w, -r3.z, v2.w, l(1.000000)
add_sat r1.w, -r1.w, l(1.000000)
mad r0.xyz, r4.xyzx, r1.wwww, r0.xyzx
mul r0.xyz, r1.xyzx, r0.xyzx
mad r1.xyz, r3.xywx, r1.wwww, r2.xyzx
mad r0.xyz, r0.xyzx, r0.wwww, r1.xyzx
switch cb5[11].x
  case l(1)
  case l(3)
  add r1.y, cb5[12].z, cb5[13].y
  add r2.xyz, -v6.xyzx, cb6[9].xyzx
  dp3 r1.z, r2.xyzx, r2.xyzx
  sqrt r1.z, r1.z
  lt r1.w, cb6[9].y, r1.y
  if_nz r1.w
    add r2.x, v6.y, -cb6[9].y
    max r2.x, r2.x, l(0.000000)
    add r2.x, r2.x, l(0.000010)
    add r2.y, r1.y, -cb6[9].y
    div_sat r2.x, r2.y, r2.x
    mul r2.y, r1.z, r2.x
    mad r2.z, -r1.z, r2.x, r1.z
    lt r2.w, l(0.000000), r2.z
    if_nz r2.w
      add r2.x, -r2.x, l(1.000000)
      mul r2.x, r1.z, r2.x
      add r2.w, -r1.y, v6.y
      add r3.x, r2.z, l(0.000010)
      div r3.y, |r2.w|, r3.x
      mul r3.y, r3.y, cb5[10].x
      eq r3.z, r3.y, l(0.000000)
      mul r3.w, r2.x, -r3.y
      mul r3.w, r3.w, l(1.442695)
      exp r3.w, r3.w
      add r3.w, -r3.w, l(1.000000)
      div r3.y, r3.w, r3.y
      movc r3.y, r3.z, r2.x, r3.y
      min r3.z, r1.y, v6.y
      mul r3.z, r3.z, -cb5[10].x
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      mul r3.z, r3.z, -cb5[10].y
      mul r3.y, r3.y, r3.z
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      min r3.y, r3.y, l(1.000000)
      div r2.w, r2.w, r3.x
      mul r2.w, r2.w, cb0[14].z
      eq r3.x, r2.w, l(0.000000)
      mul r3.z, r2.x, -r2.w
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      add r3.z, -r3.z, l(1.000000)
      div r2.w, r3.z, r2.w
      movc r2.x, r3.x, r2.x, r2.w
      add r2.w, r1.y, -cb0[14].x
      mul r2.w, r2.w, -cb0[14].z
      mul r2.w, r2.w, l(1.442695)
      exp r2.w, r2.w
      mul r2.w, r2.w, -cb0[14].y
      mul r2.x, r2.x, r2.w
      mul r2.x, r2.x, l(1.442695)
      exp r2.x, r2.x
      min r2.x, r2.x, l(1.000000)
      mul r2.x, r2.x, r3.y
    else 
      mov r2.x, l(1.000000)
    endif 
    mul r2.y, r2.y, -cb5[12].w
    mul r2.y, r2.y, l(1.442695)
    exp r2.y, r2.y
    min r2.y, r2.y, l(1.000000)
  else 
    add r2.w, -v6.y, cb6[9].y
    max r2.w, r2.w, l(0.000000)
    add r2.w, r2.w, l(0.000010)
    add r3.x, -r1.y, cb6[9].y
    div_sat r2.w, r3.x, r2.w
    mul r2.z, r1.z, r2.w
    mad r3.x, -r1.z, r2.w, r1.z
    max r1.y, r1.y, v6.y
    add r3.y, r1.y, -cb6[9].y
    mad r1.z, r1.z, r2.w, l(0.000010)
    div r2.w, |r3.y|, r1.z
    mul r2.w, r2.w, cb5[10].x
    eq r3.z, r2.w, l(0.000000)
    mul r3.w, r2.z, -r2.w
    mul r3.w, r3.w, l(1.442695)
    exp r3.w, r3.w
    add r3.w, -r3.w, l(1.000000)
    div r2.w, r3.w, r2.w
    movc r2.w, r3.z, r2.z, r2.w
    min r1.y, r1.y, cb6[9].y
    mul r1.y, r1.y, -cb5[10].x
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    mul r1.y, r1.y, -cb5[10].y
    mul r1.y, r2.w, r1.y
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    div r1.z, r3.y, r1.z
    mul r1.z, r1.z, cb0[14].z
    eq r2.w, r1.z, l(0.000000)
    mul r3.y, r2.z, -r1.z
    mul r3.y, r3.y, l(1.442695)
    exp r3.y, r3.y
    add r3.y, -r3.y, l(1.000000)
    div r1.z, r3.y, r1.z
    movc r1.z, r2.w, r2.z, r1.z
    add r2.w, -cb0[14].x, cb6[9].y
    mul r2.w, r2.w, -cb0[14].z
    mul r2.w, r2.w, l(1.442695)
    exp r2.w, r2.w
    mul r2.w, r2.w, -cb0[14].y
    mul r1.z, r1.z, r2.w
    mul r1.z, r1.z, l(1.442695)
    exp r1.z, r1.z
    min r1.yz, r1.yyzy, l(0.000000, 1.000000, 1.000000, 0.000000)
    mul r2.x, r1.z, r1.y
    mul r1.y, r3.x, -cb5[12].w
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    min r2.y, r1.y, l(1.000000)
  endif 
  add r1.y, -r2.z, cb5[12].x
  mul_sat r1.y, r1.y, cb5[12].y
  mul r1.z, r1.y, r2.x
  add r3.xyz, v6.xyzx, -cb6[9].xyzx
  dp3 r2.z, r3.xyzx, r3.xyzx
  rsq r2.z, r2.z
  mul r2.w, r2.z, r3.y
  lt r3.x, r2.w, l(0.000000)
  mad r2.z, r3.y, r2.z, l(1.000000)
  mul r2.z, r2.z, r2.z
  add r3.yz, -cb0[17].xxyx, cb0[17].yyzy
  mad r2.z, r2.z, r3.y, cb0[17].x
  mad r2.w, r2.w, r3.z, cb0[17].y
  movc r2.z, r3.x, r2.z, r2.w
  mul r3.xyz, r2.zzzz, cb0[7].xyzx
  mul r3.xyz, r0.wwww, r3.xyzx
  mul r4.xyz, r0.wwww, cb0[1].xyzx
  mad r5.x, -r2.x, r1.y, l(1.000000)
  mul r6.x, r2.y, r5.x
  add r6.y, -r2.y, l(1.000000)
  mul r6.z, r2.y, r1.z
  mul r5.y, r1.z, r6.y
  mov r5.z, r6.z
  movc r1.yzw, r1.wwww, r6.xxyz, r5.xxyz
  mul r2.xyz, r1.zzzz, r3.xyzx
  mad r2.xyz, r4.xyzx, r1.yyyy, r2.xyzx
  mad r0.xyz, r0.xyzx, r1.wwww, r2.xyzx
  mov r1.x, l(1.000000)
  break 
  case l(2)
  add r1.y, cb5[12].z, cb5[13].y
  add r2.xyz, -v6.xyzx, cb6[9].xyzx
  dp3 r1.z, r2.xyzx, r2.xyzx
  sqrt r1.z, r1.z
  lt r1.w, cb6[9].y, r1.y
  if_nz r1.w
    add r1.w, v6.y, -cb6[9].y
    max r1.w, r1.w, l(0.000000)
    add r1.w, r1.w, l(0.000010)
    add r2.x, r1.y, -cb6[9].y
    div_sat r1.w, r2.x, r1.w
    mul r2.x, r1.w, r1.z
    mad r2.y, -r1.z, r1.w, r1.z
    lt r2.z, l(0.000000), r2.y
    if_nz r2.z
      add r1.w, -r1.w, l(1.000000)
      mul r1.w, r1.w, r1.z
      add r2.z, -r1.y, v6.y
      add r2.w, r2.y, l(0.000010)
      div r3.x, |r2.z|, r2.w
      mul r3.x, r3.x, cb5[10].x
      eq r3.y, r3.x, l(0.000000)
      mul r3.z, r1.w, -r3.x
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      add r3.z, -r3.z, l(1.000000)
      div r3.x, r3.z, r3.x
      movc r3.x, r3.y, r1.w, r3.x
      min r3.y, r1.y, v6.y
      mul r3.y, r3.y, -cb5[10].x
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      mul r3.y, r3.y, -cb5[10].y
      mul r3.x, r3.x, r3.y
      mul r3.x, r3.x, l(1.442695)
      exp r3.x, r3.x
      min r3.x, r3.x, l(1.000000)
      div r2.z, r2.z, r2.w
      mul r2.z, r2.z, cb0[14].z
      eq r2.w, r2.z, l(0.000000)
      mul r3.y, r1.w, -r2.z
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      add r3.y, -r3.y, l(1.000000)
      div r2.z, r3.y, r2.z
      movc r1.w, r2.w, r1.w, r2.z
      add r2.z, r1.y, -cb0[14].x
      mul r2.z, r2.z, -cb0[14].z
      mul r2.z, r2.z, l(1.442695)
      exp r2.z, r2.z
      mul r2.z, r2.z, -cb0[14].y
      mul r1.w, r1.w, r2.z
      mul r1.w, r1.w, l(1.442695)
      exp r1.w, r1.w
      min r1.w, r1.w, l(1.000000)
      mul r3.x, r1.w, r3.x
    else 
      mov r3.x, l(1.000000)
    endif 
    mul r1.w, r2.x, -cb5[12].w
    mul r1.w, r1.w, l(1.442695)
    exp r1.w, r1.w
    min r3.y, r1.w, l(1.000000)
  else 
    add r1.w, -v6.y, cb6[9].y
    max r1.w, r1.w, l(0.000000)
    add r1.w, r1.w, l(0.000010)
    add r2.x, -r1.y, cb6[9].y
    div_sat r1.w, r2.x, r1.w
    mul r2.y, r1.w, r1.z
    mad r2.x, -r1.z, r1.w, r1.z
    max r1.y, r1.y, v6.y
    add r2.z, r1.y, -cb6[9].y
    mad r1.z, r1.z, r1.w, l(0.000010)
    div r1.w, |r2.z|, r1.z
    mul r1.w, r1.w, cb5[10].x
    eq r2.w, r1.w, l(0.000000)
    mul r3.z, r2.y, -r1.w
    mul r3.z, r3.z, l(1.442695)
    exp r3.z, r3.z
    add r3.z, -r3.z, l(1.000000)
    div r1.w, r3.z, r1.w
    movc r1.w, r2.w, r2.y, r1.w
    min r1.y, r1.y, cb6[9].y
    mul r1.y, r1.y, -cb5[10].x
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    mul r1.y, r1.y, -cb5[10].y
    mul r1.y, r1.w, r1.y
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    div r1.z, r2.z, r1.z
    mul r1.z, r1.z, cb0[14].z
    eq r1.w, r1.z, l(0.000000)
    mul r2.z, r2.y, -r1.z
    mul r2.z, r2.z, l(1.442695)
    exp r2.z, r2.z
    add r2.z, -r2.z, l(1.000000)
    div r1.z, r2.z, r1.z
    movc r1.z, r1.w, r2.y, r1.z
    add r1.w, -cb0[14].x, cb6[9].y
    mul r1.w, r1.w, -cb0[14].z
    mul r1.w, r1.w, l(1.442695)
    exp r1.w, r1.w
    mul r1.w, r1.w, -cb0[14].y
    mul r1.z, r1.z, r1.w
    mul r1.z, r1.z, l(1.442695)
    exp r1.z, r1.z
    min r1.yz, r1.yyzy, l(0.000000, 1.000000, 1.000000, 0.000000)
    mul r3.x, r1.z, r1.y
    mul r1.y, r2.x, -cb5[12].w
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    min r3.y, r1.y, l(1.000000)
  endif 
  add r1.y, -r2.y, cb5[12].x
  mul_sat r1.y, r1.y, cb5[12].y
  mul r1.y, r1.y, r3.x
  mul r1.x, r3.y, r1.y
  break 
  default 
  mov r1.x, l(1.000000)
  break 
endswitch 
mul o0.xyzw, r0.xyzw, r1.xxxx
ret 
// Approximately 0 instruction slots used

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
